$(function () {
  const { layer, form } = layui;
  initCate();
  // 定义加载文章分类的方法
  function initCate() {
    $.ajax({
      method: "GET",
      url: "/my/article/cates",
      success: function (res) {
        if (res.status !== 0) {
          return layer.msg("初始化文章分类失败！");
        }
        // 调用模板引擎，渲染分类的下拉菜单
        var htmlStr = template("tpl-cate", res);
        $("[name=cate_id]").html(htmlStr);
        // 一定要记得调用 form.render() 方法 重新渲染form
        form.render();
      },
    });
  }
  // 初始化富文本编辑器
  initEditor();
  // 1. 初始化图片裁剪器
  var $image = $("#image");

  // 2. 裁剪选项
  var options = {
    aspectRatio: 400 / 280,
    preview: ".img-preview",
  };

  // 3. 初始化裁剪区域
  $image.cropper(options);
  $("#btnChooseImage").on("click", function () {
    $("#coverFile").click();
  });
  $("#coverFile").on("change", function (e) {
    const files = e.target.files;
    if (files.length === 0) return;
    // 根据文件，创建对应的 URL 地址
    var newImgURL = URL.createObjectURL(files[0]);
    // 为裁剪区域重新设置图片
    $image
      .cropper("destroy") // 销毁旧的裁剪区域
      .attr("src", newImgURL) // 重新设置图片路径
      .cropper(options); // 重新初始化裁剪区域
  });
 let art_state = "已发布";
  $("#btnSave2").on("click", function () {
    art_state = "草稿";
  });
  $("#form-pub").on("submit", function (e) {
    //  阻止表单的默认提交行为
    e.preventDefault();
    const fd = new FormData(this);
    fd.append("state", art_state);
    // fd.forEach((v, k) => {
    //   console.log(v, k);
    // });
        // 4. 将封面裁剪过后的图片，输出为一个文件对象
        $image
        .cropper('getCroppedCanvas', {
          // 创建一个 Canvas 画布
          width: 400,
          height: 280
        })
        .toBlob(function(blob) {
          // 将 Canvas 画布上的内容，转化为文件对象
          // 得到文件对象后，进行后续的操作
          // 5. 将文件对象，存储到 fd 中
          fd.append('cover_img',blob)
          // 6. 发起 ajax 数据请求
          publishArticle(fd)
        })
  });
  function publishArticle(fd){
    $.ajax({
      method:'POST',
      url:'/my/article/add',
      data:fd,
      contentType: false,
      processData: false,
      success:function(res){
        if(res.status!==0){
          return layer.msg('发布文章失败！')
        }
        layer.msg('发布文章成功！')
        location.href='/article/art_list.html'
      }

    })
  }
});
